package com.lingnan.service;


import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.service.IService;
import com.lingnan.dto.JobPositionPageDto;
import com.lingnan.dto.JobPositionQueryParam;
import com.lingnan.dto.JobPositionSaveParam;
import com.lingnan.entity.po.JobPosition;

import java.util.List;
import java.util.Map;

/**
* @author abc20
* @description 针对表【job_position(企业招聘职位表)】的数据库操作Service
* @createDate 2025-07-21 14:35:19
*/
public interface JobPositionService extends IService<JobPosition> {


    /**
     * 增加职位浏览次数
     * @param id 职位ID
     * @return 是否更新成功
     */
    boolean incrementViewCount(Long id);

    /**
     * 根据id列表查询职位
     * @param ids
     * @return
     */
    List<JobPosition> getJobPositionByIds(List<Long> ids);


    /**
     * 分页多条件查询职位信息
     * @param pageNum 页码
     * @param pageSize 页大小
     * @param queryParam 查询参数
     * @return 分页结果
     */
    IPage<JobPositionPageDto> getListByQueryParam(int pageNum, int pageSize, JobPositionQueryParam queryParam);

    /**
     * 查询所有职位信息
     */
    Map<String, Integer> getAllJobTypeCounts();

    /**
     * 保存职位信息（新增或编辑）
     */
    JobPositionPageDto saveJobPosition(JobPositionSaveParam saveParam);

    /**
     * 根据ID获取职位详情
     */
    JobPositionPageDto getJobPositionById(Long id);

    /**
     * 删除职位
     */
    void deleteJobPosition(Long id);

    /**
     * 批量删除职位
     */
    void batchDeleteJobPosition(List<Long> ids);

    /**
     * 更新职位状态
     */
    void updateJobPositionStatus(Long id, Integer status);

    /**
     * 获取职位类型百分比
     */
    Map<String, Double> getJobTypePercentages();

}
